<!DOCTYPE html>
<html lang="ja">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>Vuex とは何か？ | Vuex</title>
    <meta name="description" content="Vue.js のための集中状態管理">
    <link rel="stylesheet" href="static/css/style.34a39eef.css">
    <link rel="modulepreload" href="https://vuex.vuejs.org/assets/Home.8c77385a.js">
    <link rel="modulepreload" href="https://vuex.vuejs.org/assets/vuex.7a49333f.js">
    <link rel="modulepreload" href="https://vuex.vuejs.org/assets/app.a0c675ce.js">
    <link rel="modulepreload" href="https://vuex.vuejs.org/assets/ja_index.md.9e875040.lean.js">
    <link rel="modulepreload" href="https://vuex.vuejs.org/assets/app.a0c675ce.js">
    <link rel="icon" href="https://vuex.vuejs.org/logo.png">
    <link rel="apple-touch-icon" href="https://vuex.vuejs.org/icons/apple-touch-icon-152x152.png">
    <link rel="mask-icon" href="https://vuex.vuejs.org/icons/safari-pinned-tab.svg" color="#3eaf7c">
    <meta name="msapplication-TileImage" content="/icons/msapplication-icon-144x144.png">
    <meta name="twitter:title" content="Vuex とは何か？ | Vuex">
    <meta property="og:title" content="Vuex とは何か？ | Vuex">
  </head>
  <body>
    <div id="app"><!--[--><div class="theme"><header class="nav-bar" data-v-675d8756=""><div class="sidebar-button" data-v-675d8756=""><svg class="icon" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewbox="0 0 448 512"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z" class=""></path></svg></div><a class="nav-bar-title" href="javascript:;" aria-label="Vuex, back to home" data-v-675d8756="" data-v-4a583abe=""><!----> Vuex</a><div class="flex-grow" data-v-675d8756=""></div><div class="nav" data-v-675d8756=""><nav class="nav-links" data-v-675d8756="" data-v-eab3edfe=""><!--[--><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item" href="javascript:;" data-v-b8818f8c="">ガイド <!----></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item" href="javascript:;" data-v-b8818f8c="">API リファレンス <!----></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-b8818f8c="">リリースノート <svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-b8818f8c=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-dropdown-link" data-v-eab3edfe="" data-v-56bf3a3f=""><button class="button" data-v-56bf3a3f=""><span class="button-text" data-v-56bf3a3f="">v4.x</span><span class="right button-arrow" data-v-56bf3a3f=""></span></button><ul class="dialog" data-v-56bf3a3f=""><!--[--><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">v3.x</span><span class="icon" data-v-bbc27490=""><svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-bbc27490=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></span></a></div></li><!--]--></ul></div></div><!--]--><div class="item" data-v-eab3edfe=""><div class="nav-dropdown-link" data-v-eab3edfe="" data-v-56bf3a3f=""><button class="button" data-v-56bf3a3f=""><span class="button-text" data-v-56bf3a3f="">言語</span><span class="right button-arrow" data-v-56bf3a3f=""></span></button><ul class="dialog" data-v-56bf3a3f=""><!--[--><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index5.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">English</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index19.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">简体中文</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item active" href="" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">日本語</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index21.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">Português</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><!--]--></ul></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-b8818f8c="">GitHub <svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-b8818f8c=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div></div></nav></div><!--[--><!--]--></header><aside class="sidebar" data-v-83e92a68=""><nav class="nav-links nav" data-v-83e92a68="" data-v-eab3edfe=""><!--[--><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item" href="javascript:;" data-v-b8818f8c="">ガイド <!----></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item" href="javascript:;" data-v-b8818f8c="">API リファレンス <!----></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-b8818f8c="">リリースノート <svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-b8818f8c=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div></div><div class="item" data-v-eab3edfe=""><div class="nav-dropdown-link" data-v-eab3edfe="" data-v-56bf3a3f=""><button class="button" data-v-56bf3a3f=""><span class="button-text" data-v-56bf3a3f="">v4.x</span><span class="right button-arrow" data-v-56bf3a3f=""></span></button><ul class="dialog" data-v-56bf3a3f=""><!--[--><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">v3.x</span><span class="icon" data-v-bbc27490=""><svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-bbc27490=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></span></a></div></li><!--]--></ul></div></div><!--]--><div class="item" data-v-eab3edfe=""><div class="nav-dropdown-link" data-v-eab3edfe="" data-v-56bf3a3f=""><button class="button" data-v-56bf3a3f=""><span class="button-text" data-v-56bf3a3f="">言語</span><span class="right button-arrow" data-v-56bf3a3f=""></span></button><ul class="dialog" data-v-56bf3a3f=""><!--[--><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index5.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">English</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index19.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">简体中文</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item active" href="" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">日本語</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><li class="dialog-item" data-v-56bf3a3f=""><div class="nav-dropdown-link-item" data-v-56bf3a3f="" data-v-bbc27490=""><a class="item" href="index21.html" data-v-bbc27490=""><span class="arrow" data-v-bbc27490=""></span><span class="text" data-v-bbc27490="">Português</span><span class="icon" data-v-bbc27490=""><!----></span></a></div></li><!--]--></ul></div></div><div class="item" data-v-eab3edfe=""><div class="nav-link" data-v-eab3edfe="" data-v-b8818f8c=""><a class="item isExternal" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-b8818f8c="">GitHub <svg class="icon outbound" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-b8818f8c=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div></div></nav><!--[--><!--]--><ul class="sidebar-links" data-v-83e92a68=""><!--[--><li class="sidebar-link"><p class="sidebar-link-item">はじめに</p><ul class="sidebar-links"><li class="sidebar-link"><a class="sidebar-link-item active" href="javascript:;">Vuex とは何か？</a><ul class="sidebar-links"><li class="sidebar-link"><a class="sidebar-link-item" href="#状態管理パターン-とはなんですか？">&quot;状態管理パターン&quot;とはなんですか？</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="#いつ、vuexを使うべきでしょうか？">いつ、Vuexを使うべきでしょうか？</a><!----></li></ul></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">インストール</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">Vuex 入門</a><!----></li></ul></li><li class="sidebar-link"><p class="sidebar-link-item">コアコンセプト</p><ul class="sidebar-links"><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">ステート</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">ゲッター</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">ミューテーション</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">アクション</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">モジュール</a><!----></li></ul></li><li class="sidebar-link"><p class="sidebar-link-item">高度な活用</p><ul class="sidebar-links"><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">アプリケーションの構造</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">Composition API</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">プラグイン</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">厳格モード</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">フォームの扱い</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">テスト</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">ホットリローディング</a><!----></li><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">TypeScript サポート</a><!----></li></ul></li><li class="sidebar-link"><p class="sidebar-link-item">移行 ガイド</p><ul class="sidebar-links"><li class="sidebar-link"><a class="sidebar-link-item" href="javascript:;">3.x から 4.0 への移行</a><!----></li></ul></li><!--]--></ul><!--[--><!--]--></aside><!-- TODO: make this button accessible --><div class="sidebar-mask"></div><main class="page" data-v-7eddb2c4=""><div class="container" data-v-7eddb2c4=""><!--[--><!--]--><div style="position:relative;" class="content" data-v-7eddb2c4=""><div><h1 id="vuex-とは何か？" tabindex="-1">Vuex とは何か？ <a class="header-anchor" href="#vuex-とは何か？" aria-hidden="true">#</a></h1><div class="tip custom-block"><p class="custom-block-title">注意</p><p>これは、Vue 3 で動作する Vuex 4 のためのドキュメントです。Vue 2 で動作する Vuex 3 のドキュメントをお探しの方は、<a href="javascript:;" target="_blank" rel="noopener noreferrer">こちらをご覧ください</a>。</p></div><p>Vuex は Vue.js アプリケーションのための <strong>状態管理パターン + ライブラリ</strong>です。 これは予測可能な方法によってのみ状態の変異を行うというルールを保証し、アプリケーション内の全てのコンポーネントのための集中型のストアとして機能します。</p><h2 id="状態管理パターン-とはなんですか？" tabindex="-1">&quot;状態管理パターン&quot;とはなんですか？ <a class="header-anchor" href="#状態管理パターン-とはなんですか？" aria-hidden="true">#</a></h2><p>単純な Vue で作られたカウンターアプリをみてみましょう:</p><div class="language-js"><pre><code><span class="token keyword">const</span> Counter <span class="token operator">=</span> <span class="token punctuation">{</span>
  <span class="token comment">// state</span>
  <span class="token function">data</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
    <span class="token keyword">return</span> <span class="token punctuation">{</span>
      count<span class="token operator">:</span> <span class="token number">0</span>
    <span class="token punctuation">}</span>
  <span class="token punctuation">}</span><span class="token punctuation">,</span>
  <span class="token comment">// view</span>
  template<span class="token operator">:</span> <span class="token template-string"><span class="token template-punctuation string">`</span><span class="token string">
    &lt;div&gt;{{ count }}&lt;/div&gt;
  </span><span class="token template-punctuation string">`</span></span><span class="token punctuation">,</span>
  <span class="token comment">// actions</span>
  methods<span class="token operator">:</span> <span class="token punctuation">{</span>
    <span class="token function">increment</span> <span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
      <span class="token keyword">this</span><span class="token punctuation">.</span>count<span class="token operator">++</span>
    <span class="token punctuation">}</span>
  <span class="token punctuation">}</span>
<span class="token punctuation">}</span>

<span class="token function">createApp</span><span class="token punctuation">(</span>Counter<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">mount</span><span class="token punctuation">(</span><span class="token string">&#39;#app&#39;</span><span class="token punctuation">)</span>
</code></pre></div><p>これはいくつかの要素をアプリ自身に含んでいます:</p><ul><li><strong>状態</strong>、これは私達のアプリを動かす信頼できる情報源(the source of truth)です。</li><li><strong>ビュー</strong>、これは<strong>状態</strong>のただの宣言的なマッピングです。</li><li><strong>アクション</strong>、これは<strong>ビュー</strong>からのユーザー入力に反応して、状態の変更を可能にする方法です。</li></ul><p>これらは&quot;単方向データフロー&quot;のコンセプトの極めてシンプルな責務です:</p><p style="text-align:center;margin:2em;"><img style="width:100%;max-width:450px;" src="static/picture/flow.png"></p><p>しかし、単純さは、<strong>共通の状態を共有する複数のコンポーネントを持ったときに</strong>、すぐに破綻します:</p><ul><li>複数のビューが同じ状態に依存することがあります。</li><li>異なるビューからのアクションで、同じ状態を変更する必要があります。</li></ul><p>一つ目は、プロパティ (props) として深く入れ子になったコンポーネントに渡すのは面倒で、兄弟コンポーネントでは単純に機能しません。二つ目は、親子のインスタンスを直接参照したり、イベントを介して複数の状態のコピーを変更、同期することを試みるソリューションに頼っていることがよくあります。これらのパターンは、いずれも脆く、すぐにメンテナンスが困難なコードに繋がります。</p><p>では、コンポーネントから共有している状態を抽出し、それをグローバルシングルトンで管理するのはどうでしょうか？ これにより、コンポーネントツリーは大きな &quot;ビュー&quot; となり、どのコンポーネントもツリー内のどこにあっても状態にアクセスしたり、アクションをトリガーできます!</p><p>さらに、状態管理に関わる概念を定義、分離し、特定のルールを敷くことで、コードの構造と保守性を向上させることができます。</p><p>これが Vuex の背景にある基本的なアイディアであり、<a href="javascript:;" target="_blank" rel="noopener noreferrer">Flux</a>、 <a href="javascript:;" target="_blank" rel="noopener noreferrer">Redux</a> そして <a href="javascript:;" target="_blank" rel="noopener noreferrer">The Elm Architecture</a>から影響を受けています。 他のパターンと異なるのは、Vuex は効率的な更新のために、Vue.js の粒度の細かいリアクティビティシステムを利用するよう特別に調整して実装されたライブラリだということです。</p><p>あなたがもし対話型の方法でVuexを学びたいのであれば、<a href="javascript:;" target="_blank" rel="noopener noreferrer">Scrimba</a>のVuexコースをぜひ試してみてください。</p><p><img src="static/picture/vuex.png" alt="vuex"></p><h2 id="いつ、vuexを使うべきでしょうか？" tabindex="-1">いつ、Vuexを使うべきでしょうか？ <a class="header-anchor" href="#いつ、vuexを使うべきでしょうか？" aria-hidden="true">#</a></h2><p>Vuex は、共有状態の管理に役立ちますが、さらに概念やボイラープレートのコストがかかります。これは、短期的生産性と長期的生産性のトレードオフです。</p><p>もし、あなたが大規模な SPA を構築することなく、Vuex を導入した場合、冗長で気が遠くなるように感じるかもしれません。そう感じることは全く普通です。あなたのアプリがシンプルであれば、Vuex なしで問題ないでしょう。単純な <a href="javascript:;" target="_blank" rel="noopener noreferrer">ストアパターン</a> が必要なだけかもしれません。しかし、今あなたが中規模から大規模の SPA を構築しているなら、Vue コンポーネントの外の状態をもっとうまく扱えないか考えなくてはならない状況にあるかもしれません。その場合 Vuex は次のステップとして最適でしょう。これは Redux の作者、Dan Abramov からの良い引用です:</p><blockquote><p>Flux ライブラリは眼鏡のようなものです: あなたが必要な時にいつでも分かるのです。</p></blockquote></div></div><footer class="page-footer" data-v-7eddb2c4="" data-v-fb8d84c6=""><div class="edit" data-v-fb8d84c6=""><div class="edit-link" data-v-fb8d84c6="" data-v-1ed99556=""><a class="link" href="javascript:;" target="_blank" rel="noopener noreferrer" data-v-1ed99556="">GitHub 上でこのページを編集する <svg class="icon outbound icon" xmlns="http://www.w3.org/2000/svg" aria-hidden="true" x="0px" y="0px" viewbox="0 0 100 100" width="15" height="15" data-v-1ed99556=""><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path><polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg></a></div></div><div class="updated" data-v-fb8d84c6=""><p class="last-updated" data-v-fb8d84c6="" data-v-5797b537=""><span class="prefix" data-v-5797b537="">最終更新日時:</span><span class="datetime" data-v-5797b537=""></span></p></div></footer><div class="next-and-prev-link" data-v-7eddb2c4="" data-v-38ede35f=""><div class="container" data-v-38ede35f=""><div class="prev" data-v-38ede35f=""><!----></div><div class="next" data-v-38ede35f=""><a class="link" href="javascript:;" data-v-38ede35f=""><span class="text" data-v-38ede35f="">インストール</span><svg xmlns="http://www.w3.org/2000/svg" viewbox="0 0 24 24" class="icon icon-next" data-v-38ede35f=""><path d="M19.9,12.4c0.1-0.2,0.1-0.5,0-0.8c-0.1-0.1-0.1-0.2-0.2-0.3l-7-7c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4l5.3,5.3H5c-0.6,0-1,0.4-1,1s0.4,1,1,1h11.6l-5.3,5.3c-0.4,0.4-0.4,1,0,1.4c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3l7-7C19.8,12.6,19.9,12.5,19.9,12.4z"></path></svg></a></div></div></div><!--[--><!--]--></div></main></div><!----><!--]--></div>
    <script>__VP_HASH_MAP__ = JSON.parse("{\"api_index.md\":\"4b45326e\",\"guide_actions.md\":\"9c977133\",\"guide_composition-api.md\":\"e01a428e\",\"guide_forms.md\":\"88f1ed54\",\"guide_getters.md\":\"2c5a0a0f\",\"guide_hot-reload.md\":\"c48e843e\",\"guide_index.md\":\"9dd21f7f\",\"guide_migrating-to-4-0-from-3-x.md\":\"66bd8cdf\",\"guide_modules.md\":\"95d32beb\",\"guide_mutations.md\":\"30cb1589\",\"guide_plugins.md\":\"a5e8be4d\",\"guide_state.md\":\"cfabbe36\",\"guide_strict.md\":\"9bdbc14d\",\"guide_structure.md\":\"0ac43d49\",\"guide_testing.md\":\"94c354a4\",\"guide_typescript-support.md\":\"946e4e74\",\"index.md\":\"7af08570\",\"installation.md\":\"71c4359e\",\"ja_api_index.md\":\"8ec02de7\",\"ja_guide_actions.md\":\"42d59860\",\"ja_guide_composition-api.md\":\"cf296415\",\"ja_guide_forms.md\":\"5c31ae2d\",\"ja_guide_getters.md\":\"a77b5c1e\",\"ja_guide_hot-reload.md\":\"4d14d06a\",\"ja_guide_index.md\":\"3a822b66\",\"ja_guide_migrating-to-4-0-from-3-x.md\":\"83fc993e\",\"ja_guide_modules.md\":\"bac522b8\",\"ja_guide_mutations.md\":\"9d14eba6\",\"ja_guide_plugins.md\":\"a729ddb7\",\"ja_guide_state.md\":\"6ac0e22d\",\"ja_guide_strict.md\":\"ca0af90e\",\"ja_guide_structure.md\":\"2ced329c\",\"ja_guide_testing.md\":\"246aa11b\",\"ja_guide_typescript-support.md\":\"95cb7cd9\",\"ja_index.md\":\"9e875040\",\"ja_installation.md\":\"f8883b0e\",\"ptbr_api_index.md\":\"c4a435dc\",\"ptbr_guide_actions.md\":\"4cd5afd8\",\"ptbr_guide_composition-api.md\":\"2de3cb0f\",\"ptbr_guide_forms.md\":\"d0a4a328\",\"ptbr_guide_getters.md\":\"0c62027a\",\"ptbr_guide_hot-reload.md\":\"edbb7f15\",\"ptbr_guide_index.md\":\"811fc38d\",\"ptbr_guide_migrating-to-4-0-from-3-x.md\":\"181af949\",\"ptbr_guide_modules.md\":\"035ca19f\",\"ptbr_guide_mutations.md\":\"a2194efe\",\"ptbr_guide_plugins.md\":\"ec68cab5\",\"ptbr_guide_state.md\":\"dbf6664a\",\"ptbr_guide_strict.md\":\"97901fcf\",\"ptbr_guide_structure.md\":\"493e0d23\",\"ptbr_guide_testing.md\":\"d9697706\",\"ptbr_guide_typescript-support.md\":\"d953d20b\",\"ptbr_index.md\":\"ce9751cf\",\"ptbr_installation.md\":\"fd9a58ca\",\"zh_api_index.md\":\"23227cff\",\"zh_guide_actions.md\":\"da25dd64\",\"zh_guide_composition-api.md\":\"9749c62a\",\"zh_guide_forms.md\":\"86e4b348\",\"zh_guide_getters.md\":\"d1f15af9\",\"zh_guide_hot-reload.md\":\"4832723a\",\"zh_guide_index.md\":\"6acb073d\",\"zh_guide_migrating-to-4-0-from-3-x.md\":\"9fad3617\",\"zh_guide_modules.md\":\"ce6036f0\",\"zh_guide_mutations.md\":\"2d3a9d53\",\"zh_guide_plugins.md\":\"8ab716ca\",\"zh_guide_state.md\":\"bacdc670\",\"zh_guide_strict.md\":\"99f28b75\",\"zh_guide_structure.md\":\"40f32e7f\",\"zh_guide_testing.md\":\"4d60bd56\",\"zh_guide_typescript-support.md\":\"a45beb7b\",\"zh_index.md\":\"a3d6a61d\",\"zh_installation.md\":\"14a19a2b\"}")</script>
    <script type="module" async="" src="static/js/app.a0c675ce.js"></script>
    
  </body>
</html>